package com.hehui.module.goods.entity;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;

public class GoodsCategoryExample {
    protected String orderByClause;

    protected boolean distinct;

    protected List<Criteria> oredCriteria;

    public GoodsCategoryExample() {
        oredCriteria = new ArrayList<Criteria>();
    }

    public void setOrderByClause(String orderByClause) {
        this.orderByClause = orderByClause;
    }

    public String getOrderByClause() {
        return orderByClause;
    }

    public void setDistinct(boolean distinct) {
        this.distinct = distinct;
    }

    public boolean isDistinct() {
        return distinct;
    }

    public List<Criteria> getOredCriteria() {
        return oredCriteria;
    }

    public void or(Criteria criteria) {
        oredCriteria.add(criteria);
    }

    public Criteria or() {
        Criteria criteria = createCriteriaInternal();
        oredCriteria.add(criteria);
        return criteria;
    }

    public Criteria createCriteria() {
        Criteria criteria = createCriteriaInternal();
        if (oredCriteria.size() == 0) {
            oredCriteria.add(criteria);
        }
        return criteria;
    }

    protected Criteria createCriteriaInternal() {
        Criteria criteria = new Criteria();
        return criteria;
    }

    public void clear() {
        oredCriteria.clear();
        orderByClause = null;
        distinct = false;
    }

    protected abstract static class GeneratedCriteria {
        protected List<Criterion> criteria;

        protected GeneratedCriteria() {
            super();
            criteria = new ArrayList<Criterion>();
        }

        public boolean isValid() {
            return criteria.size() > 0;
        }

        public List<Criterion> getAllCriteria() {
            return criteria;
        }

        public List<Criterion> getCriteria() {
            return criteria;
        }

        protected void addCriterion(String condition) {
            if (condition == null) {
                throw new RuntimeException("Value for condition cannot be null");
            }
            criteria.add(new Criterion(condition));
        }

        protected void addCriterion(String condition, Object value, String property) {
            if (value == null) {
                throw new RuntimeException("Value for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value));
        }

        protected void addCriterion(String condition, Object value1, Object value2, String property) {
            if (value1 == null || value2 == null) {
                throw new RuntimeException("Between values for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value1, value2));
        }

        public Criteria andGcCategoryIsNull() {
            addCriterion("gc_category is null");
            return (Criteria) this;
        }

        public Criteria andGcCategoryIsNotNull() {
            addCriterion("gc_category is not null");
            return (Criteria) this;
        }

        public Criteria andGcCategoryEqualTo(Long value) {
            addCriterion("gc_category =", value, "gcCategory");
            return (Criteria) this;
        }

        public Criteria andGcCategoryNotEqualTo(Long value) {
            addCriterion("gc_category <>", value, "gcCategory");
            return (Criteria) this;
        }

        public Criteria andGcCategoryGreaterThan(Long value) {
            addCriterion("gc_category >", value, "gcCategory");
            return (Criteria) this;
        }

        public Criteria andGcCategoryGreaterThanOrEqualTo(Long value) {
            addCriterion("gc_category >=", value, "gcCategory");
            return (Criteria) this;
        }

        public Criteria andGcCategoryLessThan(Long value) {
            addCriterion("gc_category <", value, "gcCategory");
            return (Criteria) this;
        }

        public Criteria andGcCategoryLessThanOrEqualTo(Long value) {
            addCriterion("gc_category <=", value, "gcCategory");
            return (Criteria) this;
        }

        public Criteria andGcCategoryIn(List<Long> values) {
            addCriterion("gc_category in", values, "gcCategory");
            return (Criteria) this;
        }

        public Criteria andGcCategoryNotIn(List<Long> values) {
            addCriterion("gc_category not in", values, "gcCategory");
            return (Criteria) this;
        }

        public Criteria andGcCategoryBetween(Long value1, Long value2) {
            addCriterion("gc_category between", value1, value2, "gcCategory");
            return (Criteria) this;
        }

        public Criteria andGcCategoryNotBetween(Long value1, Long value2) {
            addCriterion("gc_category not between", value1, value2, "gcCategory");
            return (Criteria) this;
        }

        public Criteria andGcMerchantidIsNull() {
            addCriterion("gc_merchantId is null");
            return (Criteria) this;
        }

        public Criteria andGcMerchantidIsNotNull() {
            addCriterion("gc_merchantId is not null");
            return (Criteria) this;
        }

        public Criteria andGcMerchantidEqualTo(Long value) {
            addCriterion("gc_merchantId =", value, "gcMerchantid");
            return (Criteria) this;
        }

        public Criteria andGcMerchantidNotEqualTo(Long value) {
            addCriterion("gc_merchantId <>", value, "gcMerchantid");
            return (Criteria) this;
        }

        public Criteria andGcMerchantidGreaterThan(Long value) {
            addCriterion("gc_merchantId >", value, "gcMerchantid");
            return (Criteria) this;
        }

        public Criteria andGcMerchantidGreaterThanOrEqualTo(Long value) {
            addCriterion("gc_merchantId >=", value, "gcMerchantid");
            return (Criteria) this;
        }

        public Criteria andGcMerchantidLessThan(Long value) {
            addCriterion("gc_merchantId <", value, "gcMerchantid");
            return (Criteria) this;
        }

        public Criteria andGcMerchantidLessThanOrEqualTo(Long value) {
            addCriterion("gc_merchantId <=", value, "gcMerchantid");
            return (Criteria) this;
        }

        public Criteria andGcMerchantidIn(List<Long> values) {
            addCriterion("gc_merchantId in", values, "gcMerchantid");
            return (Criteria) this;
        }

        public Criteria andGcMerchantidNotIn(List<Long> values) {
            addCriterion("gc_merchantId not in", values, "gcMerchantid");
            return (Criteria) this;
        }

        public Criteria andGcMerchantidBetween(Long value1, Long value2) {
            addCriterion("gc_merchantId between", value1, value2, "gcMerchantid");
            return (Criteria) this;
        }

        public Criteria andGcMerchantidNotBetween(Long value1, Long value2) {
            addCriterion("gc_merchantId not between", value1, value2, "gcMerchantid");
            return (Criteria) this;
        }

        public Criteria andGcNumIsNull() {
            addCriterion("gc_num is null");
            return (Criteria) this;
        }

        public Criteria andGcNumIsNotNull() {
            addCriterion("gc_num is not null");
            return (Criteria) this;
        }

        public Criteria andGcNumEqualTo(String value) {
            addCriterion("gc_num =", value, "gcNum");
            return (Criteria) this;
        }

        public Criteria andGcNumNotEqualTo(String value) {
            addCriterion("gc_num <>", value, "gcNum");
            return (Criteria) this;
        }

        public Criteria andGcNumGreaterThan(String value) {
            addCriterion("gc_num >", value, "gcNum");
            return (Criteria) this;
        }

        public Criteria andGcNumGreaterThanOrEqualTo(String value) {
            addCriterion("gc_num >=", value, "gcNum");
            return (Criteria) this;
        }

        public Criteria andGcNumLessThan(String value) {
            addCriterion("gc_num <", value, "gcNum");
            return (Criteria) this;
        }

        public Criteria andGcNumLessThanOrEqualTo(String value) {
            addCriterion("gc_num <=", value, "gcNum");
            return (Criteria) this;
        }

        public Criteria andGcNumLike(String value) {
            addCriterion("gc_num like", value, "gcNum");
            return (Criteria) this;
        }

        public Criteria andGcNumNotLike(String value) {
            addCriterion("gc_num not like", value, "gcNum");
            return (Criteria) this;
        }

        public Criteria andGcNumIn(List<String> values) {
            addCriterion("gc_num in", values, "gcNum");
            return (Criteria) this;
        }

        public Criteria andGcNumNotIn(List<String> values) {
            addCriterion("gc_num not in", values, "gcNum");
            return (Criteria) this;
        }

        public Criteria andGcNumBetween(String value1, String value2) {
            addCriterion("gc_num between", value1, value2, "gcNum");
            return (Criteria) this;
        }

        public Criteria andGcNumNotBetween(String value1, String value2) {
            addCriterion("gc_num not between", value1, value2, "gcNum");
            return (Criteria) this;
        }

        public Criteria andGcParentidIsNull() {
            addCriterion("gc_parentId is null");
            return (Criteria) this;
        }

        public Criteria andGcParentidIsNotNull() {
            addCriterion("gc_parentId is not null");
            return (Criteria) this;
        }

        public Criteria andGcParentidEqualTo(Long value) {
            addCriterion("gc_parentId =", value, "gcParentid");
            return (Criteria) this;
        }

        public Criteria andGcParentidNotEqualTo(Long value) {
            addCriterion("gc_parentId <>", value, "gcParentid");
            return (Criteria) this;
        }

        public Criteria andGcParentidGreaterThan(Long value) {
            addCriterion("gc_parentId >", value, "gcParentid");
            return (Criteria) this;
        }

        public Criteria andGcParentidGreaterThanOrEqualTo(Long value) {
            addCriterion("gc_parentId >=", value, "gcParentid");
            return (Criteria) this;
        }

        public Criteria andGcParentidLessThan(Long value) {
            addCriterion("gc_parentId <", value, "gcParentid");
            return (Criteria) this;
        }

        public Criteria andGcParentidLessThanOrEqualTo(Long value) {
            addCriterion("gc_parentId <=", value, "gcParentid");
            return (Criteria) this;
        }

        public Criteria andGcParentidIn(List<Long> values) {
            addCriterion("gc_parentId in", values, "gcParentid");
            return (Criteria) this;
        }

        public Criteria andGcParentidNotIn(List<Long> values) {
            addCriterion("gc_parentId not in", values, "gcParentid");
            return (Criteria) this;
        }

        public Criteria andGcParentidBetween(Long value1, Long value2) {
            addCriterion("gc_parentId between", value1, value2, "gcParentid");
            return (Criteria) this;
        }

        public Criteria andGcParentidNotBetween(Long value1, Long value2) {
            addCriterion("gc_parentId not between", value1, value2, "gcParentid");
            return (Criteria) this;
        }

        public Criteria andGcNameIsNull() {
            addCriterion("gc_name is null");
            return (Criteria) this;
        }

        public Criteria andGcNameIsNotNull() {
            addCriterion("gc_name is not null");
            return (Criteria) this;
        }

        public Criteria andGcNameEqualTo(String value) {
            addCriterion("gc_name =", value, "gcName");
            return (Criteria) this;
        }

        public Criteria andGcNameNotEqualTo(String value) {
            addCriterion("gc_name <>", value, "gcName");
            return (Criteria) this;
        }

        public Criteria andGcNameGreaterThan(String value) {
            addCriterion("gc_name >", value, "gcName");
            return (Criteria) this;
        }

        public Criteria andGcNameGreaterThanOrEqualTo(String value) {
            addCriterion("gc_name >=", value, "gcName");
            return (Criteria) this;
        }

        public Criteria andGcNameLessThan(String value) {
            addCriterion("gc_name <", value, "gcName");
            return (Criteria) this;
        }

        public Criteria andGcNameLessThanOrEqualTo(String value) {
            addCriterion("gc_name <=", value, "gcName");
            return (Criteria) this;
        }

        public Criteria andGcNameLike(String value) {
            addCriterion("gc_name like", value, "gcName");
            return (Criteria) this;
        }

        public Criteria andGcNameNotLike(String value) {
            addCriterion("gc_name not like", value, "gcName");
            return (Criteria) this;
        }

        public Criteria andGcNameIn(List<String> values) {
            addCriterion("gc_name in", values, "gcName");
            return (Criteria) this;
        }

        public Criteria andGcNameNotIn(List<String> values) {
            addCriterion("gc_name not in", values, "gcName");
            return (Criteria) this;
        }

        public Criteria andGcNameBetween(String value1, String value2) {
            addCriterion("gc_name between", value1, value2, "gcName");
            return (Criteria) this;
        }

        public Criteria andGcNameNotBetween(String value1, String value2) {
            addCriterion("gc_name not between", value1, value2, "gcName");
            return (Criteria) this;
        }

        public Criteria andGcLevelIsNull() {
            addCriterion("gc_level is null");
            return (Criteria) this;
        }

        public Criteria andGcLevelIsNotNull() {
            addCriterion("gc_level is not null");
            return (Criteria) this;
        }

        public Criteria andGcLevelEqualTo(String value) {
            addCriterion("gc_level =", value, "gcLevel");
            return (Criteria) this;
        }

        public Criteria andGcLevelNotEqualTo(String value) {
            addCriterion("gc_level <>", value, "gcLevel");
            return (Criteria) this;
        }

        public Criteria andGcLevelGreaterThan(String value) {
            addCriterion("gc_level >", value, "gcLevel");
            return (Criteria) this;
        }

        public Criteria andGcLevelGreaterThanOrEqualTo(String value) {
            addCriterion("gc_level >=", value, "gcLevel");
            return (Criteria) this;
        }

        public Criteria andGcLevelLessThan(String value) {
            addCriterion("gc_level <", value, "gcLevel");
            return (Criteria) this;
        }

        public Criteria andGcLevelLessThanOrEqualTo(String value) {
            addCriterion("gc_level <=", value, "gcLevel");
            return (Criteria) this;
        }

        public Criteria andGcLevelLike(String value) {
            addCriterion("gc_level like", value, "gcLevel");
            return (Criteria) this;
        }

        public Criteria andGcLevelNotLike(String value) {
            addCriterion("gc_level not like", value, "gcLevel");
            return (Criteria) this;
        }

        public Criteria andGcLevelIn(List<String> values) {
            addCriterion("gc_level in", values, "gcLevel");
            return (Criteria) this;
        }

        public Criteria andGcLevelNotIn(List<String> values) {
            addCriterion("gc_level not in", values, "gcLevel");
            return (Criteria) this;
        }

        public Criteria andGcLevelBetween(String value1, String value2) {
            addCriterion("gc_level between", value1, value2, "gcLevel");
            return (Criteria) this;
        }

        public Criteria andGcLevelNotBetween(String value1, String value2) {
            addCriterion("gc_level not between", value1, value2, "gcLevel");
            return (Criteria) this;
        }

        public Criteria andGcTopIsNull() {
            addCriterion("gc_top is null");
            return (Criteria) this;
        }

        public Criteria andGcTopIsNotNull() {
            addCriterion("gc_top is not null");
            return (Criteria) this;
        }

        public Criteria andGcTopEqualTo(Integer value) {
            addCriterion("gc_top =", value, "gcTop");
            return (Criteria) this;
        }

        public Criteria andGcTopNotEqualTo(Integer value) {
            addCriterion("gc_top <>", value, "gcTop");
            return (Criteria) this;
        }

        public Criteria andGcTopGreaterThan(Integer value) {
            addCriterion("gc_top >", value, "gcTop");
            return (Criteria) this;
        }

        public Criteria andGcTopGreaterThanOrEqualTo(Integer value) {
            addCriterion("gc_top >=", value, "gcTop");
            return (Criteria) this;
        }

        public Criteria andGcTopLessThan(Integer value) {
            addCriterion("gc_top <", value, "gcTop");
            return (Criteria) this;
        }

        public Criteria andGcTopLessThanOrEqualTo(Integer value) {
            addCriterion("gc_top <=", value, "gcTop");
            return (Criteria) this;
        }

        public Criteria andGcTopIn(List<Integer> values) {
            addCriterion("gc_top in", values, "gcTop");
            return (Criteria) this;
        }

        public Criteria andGcTopNotIn(List<Integer> values) {
            addCriterion("gc_top not in", values, "gcTop");
            return (Criteria) this;
        }

        public Criteria andGcTopBetween(Integer value1, Integer value2) {
            addCriterion("gc_top between", value1, value2, "gcTop");
            return (Criteria) this;
        }

        public Criteria andGcTopNotBetween(Integer value1, Integer value2) {
            addCriterion("gc_top not between", value1, value2, "gcTop");
            return (Criteria) this;
        }

        public Criteria andCreatedateIsNull() {
            addCriterion("createDate is null");
            return (Criteria) this;
        }

        public Criteria andCreatedateIsNotNull() {
            addCriterion("createDate is not null");
            return (Criteria) this;
        }

        public Criteria andCreatedateEqualTo(Date value) {
            addCriterion("createDate =", value, "createdate");
            return (Criteria) this;
        }

        public Criteria andCreatedateNotEqualTo(Date value) {
            addCriterion("createDate <>", value, "createdate");
            return (Criteria) this;
        }

        public Criteria andCreatedateGreaterThan(Date value) {
            addCriterion("createDate >", value, "createdate");
            return (Criteria) this;
        }

        public Criteria andCreatedateGreaterThanOrEqualTo(Date value) {
            addCriterion("createDate >=", value, "createdate");
            return (Criteria) this;
        }

        public Criteria andCreatedateLessThan(Date value) {
            addCriterion("createDate <", value, "createdate");
            return (Criteria) this;
        }

        public Criteria andCreatedateLessThanOrEqualTo(Date value) {
            addCriterion("createDate <=", value, "createdate");
            return (Criteria) this;
        }

        public Criteria andCreatedateIn(List<Date> values) {
            addCriterion("createDate in", values, "createdate");
            return (Criteria) this;
        }

        public Criteria andCreatedateNotIn(List<Date> values) {
            addCriterion("createDate not in", values, "createdate");
            return (Criteria) this;
        }

        public Criteria andCreatedateBetween(Date value1, Date value2) {
            addCriterion("createDate between", value1, value2, "createdate");
            return (Criteria) this;
        }

        public Criteria andCreatedateNotBetween(Date value1, Date value2) {
            addCriterion("createDate not between", value1, value2, "createdate");
            return (Criteria) this;
        }

        public Criteria andUpdatedateIsNull() {
            addCriterion("updateDate is null");
            return (Criteria) this;
        }

        public Criteria andUpdatedateIsNotNull() {
            addCriterion("updateDate is not null");
            return (Criteria) this;
        }

        public Criteria andUpdatedateEqualTo(Date value) {
            addCriterion("updateDate =", value, "updatedate");
            return (Criteria) this;
        }

        public Criteria andUpdatedateNotEqualTo(Date value) {
            addCriterion("updateDate <>", value, "updatedate");
            return (Criteria) this;
        }

        public Criteria andUpdatedateGreaterThan(Date value) {
            addCriterion("updateDate >", value, "updatedate");
            return (Criteria) this;
        }

        public Criteria andUpdatedateGreaterThanOrEqualTo(Date value) {
            addCriterion("updateDate >=", value, "updatedate");
            return (Criteria) this;
        }

        public Criteria andUpdatedateLessThan(Date value) {
            addCriterion("updateDate <", value, "updatedate");
            return (Criteria) this;
        }

        public Criteria andUpdatedateLessThanOrEqualTo(Date value) {
            addCriterion("updateDate <=", value, "updatedate");
            return (Criteria) this;
        }

        public Criteria andUpdatedateIn(List<Date> values) {
            addCriterion("updateDate in", values, "updatedate");
            return (Criteria) this;
        }

        public Criteria andUpdatedateNotIn(List<Date> values) {
            addCriterion("updateDate not in", values, "updatedate");
            return (Criteria) this;
        }

        public Criteria andUpdatedateBetween(Date value1, Date value2) {
            addCriterion("updateDate between", value1, value2, "updatedate");
            return (Criteria) this;
        }

        public Criteria andUpdatedateNotBetween(Date value1, Date value2) {
            addCriterion("updateDate not between", value1, value2, "updatedate");
            return (Criteria) this;
        }

        public Criteria andIsDelIsNull() {
            addCriterion("is_del is null");
            return (Criteria) this;
        }

        public Criteria andIsDelIsNotNull() {
            addCriterion("is_del is not null");
            return (Criteria) this;
        }

        public Criteria andIsDelEqualTo(String value) {
            addCriterion("is_del =", value, "isDel");
            return (Criteria) this;
        }

        public Criteria andIsDelNotEqualTo(String value) {
            addCriterion("is_del <>", value, "isDel");
            return (Criteria) this;
        }

        public Criteria andIsDelGreaterThan(String value) {
            addCriterion("is_del >", value, "isDel");
            return (Criteria) this;
        }

        public Criteria andIsDelGreaterThanOrEqualTo(String value) {
            addCriterion("is_del >=", value, "isDel");
            return (Criteria) this;
        }

        public Criteria andIsDelLessThan(String value) {
            addCriterion("is_del <", value, "isDel");
            return (Criteria) this;
        }

        public Criteria andIsDelLessThanOrEqualTo(String value) {
            addCriterion("is_del <=", value, "isDel");
            return (Criteria) this;
        }

        public Criteria andIsDelLike(String value) {
            addCriterion("is_del like", value, "isDel");
            return (Criteria) this;
        }

        public Criteria andIsDelNotLike(String value) {
            addCriterion("is_del not like", value, "isDel");
            return (Criteria) this;
        }

        public Criteria andIsDelIn(List<String> values) {
            addCriterion("is_del in", values, "isDel");
            return (Criteria) this;
        }

        public Criteria andIsDelNotIn(List<String> values) {
            addCriterion("is_del not in", values, "isDel");
            return (Criteria) this;
        }

        public Criteria andIsDelBetween(String value1, String value2) {
            addCriterion("is_del between", value1, value2, "isDel");
            return (Criteria) this;
        }

        public Criteria andIsDelNotBetween(String value1, String value2) {
            addCriterion("is_del not between", value1, value2, "isDel");
            return (Criteria) this;
        }

        public Criteria andIsDefIsNull() {
            addCriterion("is_def is null");
            return (Criteria) this;
        }

        public Criteria andIsDefIsNotNull() {
            addCriterion("is_def is not null");
            return (Criteria) this;
        }

        public Criteria andIsDefEqualTo(String value) {
            addCriterion("is_def =", value, "isDef");
            return (Criteria) this;
        }

        public Criteria andIsDefNotEqualTo(String value) {
            addCriterion("is_def <>", value, "isDef");
            return (Criteria) this;
        }

        public Criteria andIsDefGreaterThan(String value) {
            addCriterion("is_def >", value, "isDef");
            return (Criteria) this;
        }

        public Criteria andIsDefGreaterThanOrEqualTo(String value) {
            addCriterion("is_def >=", value, "isDef");
            return (Criteria) this;
        }

        public Criteria andIsDefLessThan(String value) {
            addCriterion("is_def <", value, "isDef");
            return (Criteria) this;
        }

        public Criteria andIsDefLessThanOrEqualTo(String value) {
            addCriterion("is_def <=", value, "isDef");
            return (Criteria) this;
        }

        public Criteria andIsDefLike(String value) {
            addCriterion("is_def like", value, "isDef");
            return (Criteria) this;
        }

        public Criteria andIsDefNotLike(String value) {
            addCriterion("is_def not like", value, "isDef");
            return (Criteria) this;
        }

        public Criteria andIsDefIn(List<String> values) {
            addCriterion("is_def in", values, "isDef");
            return (Criteria) this;
        }

        public Criteria andIsDefNotIn(List<String> values) {
            addCriterion("is_def not in", values, "isDef");
            return (Criteria) this;
        }

        public Criteria andIsDefBetween(String value1, String value2) {
            addCriterion("is_def between", value1, value2, "isDef");
            return (Criteria) this;
        }

        public Criteria andIsDefNotBetween(String value1, String value2) {
            addCriterion("is_def not between", value1, value2, "isDef");
            return (Criteria) this;
        }

        public Criteria andRemarksIsNull() {
            addCriterion("remarks is null");
            return (Criteria) this;
        }

        public Criteria andRemarksIsNotNull() {
            addCriterion("remarks is not null");
            return (Criteria) this;
        }

        public Criteria andRemarksEqualTo(String value) {
            addCriterion("remarks =", value, "remarks");
            return (Criteria) this;
        }

        public Criteria andRemarksNotEqualTo(String value) {
            addCriterion("remarks <>", value, "remarks");
            return (Criteria) this;
        }

        public Criteria andRemarksGreaterThan(String value) {
            addCriterion("remarks >", value, "remarks");
            return (Criteria) this;
        }

        public Criteria andRemarksGreaterThanOrEqualTo(String value) {
            addCriterion("remarks >=", value, "remarks");
            return (Criteria) this;
        }

        public Criteria andRemarksLessThan(String value) {
            addCriterion("remarks <", value, "remarks");
            return (Criteria) this;
        }

        public Criteria andRemarksLessThanOrEqualTo(String value) {
            addCriterion("remarks <=", value, "remarks");
            return (Criteria) this;
        }

        public Criteria andRemarksLike(String value) {
            addCriterion("remarks like", value, "remarks");
            return (Criteria) this;
        }

        public Criteria andRemarksNotLike(String value) {
            addCriterion("remarks not like", value, "remarks");
            return (Criteria) this;
        }

        public Criteria andRemarksIn(List<String> values) {
            addCriterion("remarks in", values, "remarks");
            return (Criteria) this;
        }

        public Criteria andRemarksNotIn(List<String> values) {
            addCriterion("remarks not in", values, "remarks");
            return (Criteria) this;
        }

        public Criteria andRemarksBetween(String value1, String value2) {
            addCriterion("remarks between", value1, value2, "remarks");
            return (Criteria) this;
        }

        public Criteria andRemarksNotBetween(String value1, String value2) {
            addCriterion("remarks not between", value1, value2, "remarks");
            return (Criteria) this;
        }
    }

    public static class Criteria extends GeneratedCriteria {

        protected Criteria() {
            super();
        }
    }

    public static class Criterion {
        private String condition;

        private Object value;

        private Object secondValue;

        private boolean noValue;

        private boolean singleValue;

        private boolean betweenValue;

        private boolean listValue;

        private String typeHandler;

        public String getCondition() {
            return condition;
        }

        public Object getValue() {
            return value;
        }

        public Object getSecondValue() {
            return secondValue;
        }

        public boolean isNoValue() {
            return noValue;
        }

        public boolean isSingleValue() {
            return singleValue;
        }

        public boolean isBetweenValue() {
            return betweenValue;
        }

        public boolean isListValue() {
            return listValue;
        }

        public String getTypeHandler() {
            return typeHandler;
        }

        protected Criterion(String condition) {
            super();
            this.condition = condition;
            this.typeHandler = null;
            this.noValue = true;
        }

        protected Criterion(String condition, Object value, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.typeHandler = typeHandler;
            if (value instanceof List<?>) {
                this.listValue = true;
            } else {
                this.singleValue = true;
            }
        }

        protected Criterion(String condition, Object value) {
            this(condition, value, null);
        }

        protected Criterion(String condition, Object value, Object secondValue, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.secondValue = secondValue;
            this.typeHandler = typeHandler;
            this.betweenValue = true;
        }

        protected Criterion(String condition, Object value, Object secondValue) {
            this(condition, value, secondValue, null);
        }
    }
}